package com.lqd.mall.interaction.system;


import com.fasterxml.jackson.annotation.JsonFormat;
import com.lqd.mall.interaction.annotation.Excel;
import com.lqd.mall.interaction.annotation.Excel.ColumnType;
import com.lqd.mall.interaction.basis.BasisEntity;
import lombok.Getter;
import lombok.Setter;
import lombok.experimental.Accessors;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Table;
import java.util.Date;

/**
 * 操作日志记录表 oper_log
 * 
 * @author bk
 */
@Setter
@Getter
@Entity
@Accessors(chain = true)
@Table(name = "sys_oper_log")
public class SysOperLogEntity extends BasisEntity
{
    private static final long serialVersionUID = 1L;

    /** 日志主键 */
    @Excel(name = "操作序号", cellType = ColumnType.NUMERIC)
    @Id
    @Column(name = "oper_id")
    @GeneratedValue(strategy= GenerationType.IDENTITY)
    private Long operId;

    /** 操作模块 */
    @Column(name = "title")
    @Excel(name = "操作模块")
    private String title;

    /** 业务类型（0其它 1新增 2修改 3删除） */
    @Excel(name = "业务类型", readConverterExp = "0=其它,1=新增,2=修改,3=删除,4=授权,5=导出,6=导入,7=强退,8=生成代码,9=清空数据")
    @Column(name = "business_type")
    private Integer businessType;

    /** 请求方法 */
    @Excel(name = "请求方法")
    @Column(name = "method")
    private String method;

    /** 请求方式 */
    @Excel(name = "请求方式")
    @Column(name = "request_method")
    private String requestMethod;

    /** 操作类别（0其它 1后台用户 2手机端用户） */
    @Column(name = "operator_type")
    @Excel(name = "操作类别", readConverterExp = "0=其它,1=后台用户,2=手机端用户")
    private Integer operatorType;

    /** 操作人员 */
    @Column(name = "oper_name")
    @Excel(name = "操作人员")
    private String operName;

    /** 部门名称 */
    @Excel(name = "部门名称")
    @Column(name = "dept_name")
    private String deptName;

    /** 请求url */
    @Excel(name = "请求地址")
    @Column(name = "oper_url")
    private String operUrl;

    /** 操作地址 */
    @Excel(name = "操作地址")
    @Column(name = "oper_ip")
    private String operIp;

    /** 操作地点 */
    @Excel(name = "操作地点")
    @Column(name = "oper_location")
    private String operLocation;

    /** 请求参数 */
    @Excel(name = "请求参数")
    @Column(name = "oper_param")
    private String operParam;

    /** 返回参数 */
    @Excel(name = "返回参数")
    @Column(name = "json_result")
    private String jsonResult;

    /** 操作状态（0正常 1异常） */
    @Excel(name = "状态", readConverterExp = "0=正常,1=异常")
    @Column(name = "status")
    private Integer status;

    /** 错误消息 */
    @Excel(name = "错误消息")
    @Column(name = "error_msg")
    private String errorMsg;

    /** 操作时间 */
    @Column(name = "oper_time")
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @Excel(name = "操作时间", width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss")
    private Date operTime;
    /** 操作时间 */
    @Column(name = "user_id")
    @Excel(name = "用户id", width = 30 )
    private Long userId;

}
